/* 
 * PROJECT: NyARToolkit
 * --------------------------------------------------------------------------------
 * This work is based on the ARToolKit developed by
 *   Hirokazu Kato
 *   Mark Billinghurst
 *   HITLab, University of Washington, Seattle
 * http://www.hitl.washington.edu/artoolkit/
 *
 * The NyARToolkit is Java edition ARToolKit class library.
 * Copyright (C)2008-2012 Ryo Iizuka
 * 
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as publishe
 * by the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 * 
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License for more details.
 * 
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 * 
 * For further information please contact.
 *	http://nyatla.jp/nyatoolkit/
 *	<airmail(at)ebony.plala.or.jp> or <nyatla(at)nyatla.jp>
 * 
 */
package jp.nyatla.nyartoolkit.core.types;

/**
 * このクラスは、int型の二次元の点を格納します。
 *
 */
public class NyARIntPoint2d
{
	/** X座標の値です。*/
	public int x;
	/** Y座標の値です。*/
	public int y;
	/**
	 * この関数は、指定サイズのオブジェクト配列を作ります。
	 * @param i_number
	 * 作成する配列の長さ
	 * @return
	 * 新しい配列。
	 */
	public static NyARIntPoint2d[] createArray(int i_number)
	{
		NyARIntPoint2d[] ret=new NyARIntPoint2d[i_number];
		for(int i=0;i<i_number;i++)
		{
			ret[i]=new NyARIntPoint2d();
		}
		return ret;
	}
	/**
	 * この関数は、配列の値をコピーします。
	 * 配列の長さは、同じである必要があります。
	 * @param i_from
	 * コピー元の配列
	 * @param i_to
	 * コピー先の配列
	 */
	public static void copyArray(final NyARIntPoint2d[] i_from,NyARIntPoint2d[] i_to)
	{
		for(int i=i_from.length-1;i>=0;i--)
		{
			i_to[i].x=i_from[i].x;
			i_to[i].y=i_from[i].y;
		}
		return;
	}
	public static void shiftCopy(NyARDoublePoint2d[] i_src,NyARIntPoint2d[] i_dst,int i_shift)
	{
		int l=i_src.length;
		for(int i=l-1;i>=0;i--){
			int n=(i+i_shift)%l;
			i_dst[i].x=(int)i_src[n].x;
			i_dst[i].y=(int)i_src[n].y;
		}		
	}
	public static void shiftCopy(NyARIntPoint2d[] i_src,NyARIntPoint2d[] i_dst,int i_shift)
	{
		int l=i_src.length;
		for(int i=l-1;i>=0;i--){
			int n=(i+i_shift)%l;
			i_dst[i].x=i_src[n].x;
			i_dst[i].y=i_src[n].y;
		}		
	}
	/**
	 * この関数は、頂点集合から、中央値(Σp[n]/n)を求めます。
	 * @param i_points
	 * 頂点集合を格納した配列です。
	 * @param i_number_of_data
	 * 配列中の有効な頂点数です。
	 * @param o_out
	 * 中央値を受け取るオブジェクトです。
	 * @deprecated
	 * {@link #setCenterPos(NyARIntPoint2d[], int)を使用してください。
	 */
	public static void makeCenter(NyARIntPoint2d[] i_points,int i_number_of_data,NyARIntPoint2d o_out)
	{
		o_out.setCenterPos(i_points,i_number_of_data);
	}	
	/**
	 * この関数は、インスタンスの座標と、指定点との距離の２乗値を返します。
	 * @param i_p1
	 * 点の座標
	 * @return
	 * i_p1との距離の二乗値
	 */	
	public final int sqDist(NyARIntPoint2d i_p1)
	{
		int x=this.x-i_p1.x;
		int y=this.y-i_p1.y;
		return x*x+y*y;
	}
	/**
	 * この関数は、頂点集合から、中央値(Σp[n]/n)を求めて、インスタンスにセットします。
	 * @param i_point
	 * 頂点集合を格納した配列です。
	 * @param i_number_of_vertex
	 * 配列中の有効な頂点数です。
	 */	
	public final void setCenterPos(NyARIntPoint2d[] i_point,int i_number_of_vertex)
	{
		int cx,cy;
		cx=cy=0;
		for(int i=i_number_of_vertex-1;i>=0;i--){
			cx+=i_point[i].x;
			cy+=i_point[i].y;
		}
		this.x=cx/i_number_of_vertex;
		this.y=cy/i_number_of_vertex;
	}
	/**
	 * この関数は、オブジェクトからインスタンスに値をセットします。
	 * @param i_source
	 * コピー元のオブジェクト。
	 */
	public final void setValue(NyARIntPoint2d i_source)
	{
		this.x=i_source.x;
		this.y=i_source.y;
	}
	/**
	 * この関数は、オブジェクトからインスタンスに値をセットします。
	 * @param i_source
	 * コピー元のオブジェクト。
	 */	
	public final void setValue(NyARDoublePoint2d i_source)
	{
		this.x=(int)i_source.x;
		this.y=(int)i_source.y;
	}
	/**
	 * この関数は、インスタンスに値をセットします。
	 * @param i_x
	 * {@link #x}にセットする値
	 * @param i_y
	 * {@link #y}にセットする値
	 */	
	public final void setValue(int i_x,int i_y)
	{
		this.x=i_x;
		this.y=i_y;
	}
}
